<!--
~  Licensed to the Apache Software Foundation (ASF) under one or more
~  contributor license agreements.  See the NOTICE file distributed with
~  this work for additional information regarding copyright ownership.
~  The ASF licenses this file to You under the Apache License, Version 2.0
~  (the "License"); you may not use this file except in compliance with
~  the License.  You may obtain a copy of the License at
~
~     http://www.apache.org/licenses/LICENSE-2.0
~
~  Unless required by applicable law or agreed to in writing, software
~  distributed under the License is distributed on an "AS IS" BASIS,
~  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
~  See the License for the specific language governing permissions and
~  limitations under the License.
-->
<div class="policy-table h-full relative">
    <div class="listing-table overflow-y-auto absolute inset-0">
        <table
            mat-table
            [dataSource]="dataSource"
            matSort
            matSortDisableClear
            (matSortChange)="updateSort($event)"
            [matSortActive]="sort.active"
            [matSortDirection]="sort.direction">
            <!-- User column -->
            <ng-container matColumnDef="user">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>User</th>
                <td mat-cell *matCellDef="let item" class="items-center">
                    @if (item.tenantType === 'userGroup') {
                        <i class="fa fa-users primary-color mr-3"></i>
                    }
                    {{ item.user }}
                </td>
            </ng-container>

            <ng-container matColumnDef="actions">
                <th mat-header-cell *matHeaderCellDef></th>
                <td mat-cell *matCellDef="let item">
                    <div class="flex items-center justify-end gap-x-2">
                        @if (canRemove()) {
                            <button
                                mat-icon-button
                                type="button"
                                [matMenuTriggerFor]="actionMenu"
                                class="h-16 w-16 flex items-center justify-center icon global-menu">
                                <i class="fa fa-ellipsis-v"></i>
                            </button>
                        }
                        <mat-menu #actionMenu="matMenu" xPosition="before">
                            @if (canRemove()) {
                                <button mat-menu-item (click)="removeClicked(item)">
                                    <i class="fa fa-trash primary-color mr-2"></i>
                                    Remove
                                </button>
                            }
                        </mat-menu>
                    </div>
                </td>
            </ng-container>

            <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true"></tr>
            <tr
                mat-row
                *matRowDef="let row; let even = even; columns: displayedColumns"
                (click)="select(row)"
                [class.selected]="isSelected(row)"
                [class.even]="even"></tr>
        </table>
    </div>
</div>
